import requests
Python 标准库中的 urllib2 模块提供了你所需要的大多数 HTTP 功能,但是它的 API 不是特别方便使用。
requests 模块号称 HTTP for Human,它可以这样使用:
r = requests.get("http://httpbin.org/get")
r = requests.post('http://httpbin.org/post', data = {'key':'value'})
r = requests.put("http://httpbin.org/put")
r = requests.delete("http://httpbin.org/delete")
r = requests.head("http://httpbin.org/get")
r = requests.options("http://httpbin.org/get")
假如我们想访问 httpbin.org/get?key=val,我们可以使用 params 传入这些参数:
payload = {'key1': 'value1', 'key2': 'value2'}
r = requests.get("http://httpbin.org/get", params=payload)
查看 url :
print(r.url)
Requests 会自动解码来自服务器的内容。大多数 unicode 字符集都能被无缝地解码。
r = requests.get('https://github.com/timeline.json')
print r.text
查看文字编码:
r.encoding
每次改变文字编码,text 的内容也随之变化:
r.encoding = "ISO-8859-1"
r.text
Requests 中也有一个内置的 JSON 解码器处理 JSON 数据:
r.json()
如果 JSON 解码失败, r.json 就会抛出一个异常。
r = requests.get('http://httpbin.org/get')
r.status_code
r.headers['Content-Type']